# Developing Zynq Software with Xilinx SDK Lab 7 Boot from Flash



Feb 2018 Version 10



## Lab 7 Overview

With the FSBL in place, we are now ready to create a boot image and boot one of our applications from non-volatile memory. A complete boot-up requires at least three things:

- 1. FSBL
- 2. Bitstream (Optional)
- 3. Application

This Lab will show you how to combine these pieces together to create the boot image for QSPI. You will then be able to experiment with a true embedded, non-tethered boot.

# Lab 7 Objectives

When you have completed Lab 7, you will know:

- How to create a boot image
- Write and boot from QSPI



## **Experiment 1: Create the QSPI Boot Image**

The first step is to create the non-volatile boot image. This example will target booting from QSPI.

#### **Experiment 1 General Instruction:**

Change the configuration for the Peripheral Test to Release. Create a boot image for QSPI.

#### **Experiment 1 Step-by-Step Instructions:**

We first need to decide which application that we will bootload. The important consideration here is that you do not want to choose an application that will compete for the same memory resource as the FSBL. Recall from Lab 6 that the FSBL is ~150kB, targeted at the on-chip RAM\_0 and RAM\_1.

Since the Test\_Memory application runs from the same memory, this won't work. We may be able to re-design the linker script to split this application across the remaining RAMO and also RAM1, but that is beyond the scope of this experiment.

The Hello\_Zynq application is a good candidate, except recall that we targeted this application to on-chip RAM.

The Test Peripheral application is targeted at DDR. Since this application is compatible immediately with the FSBL, we will use it.

Similar to the FSBL, we will not be debugging the Test Peripheral application during this
exercise. That means we should also change the active configuration to Release to take
advantage of higher optimization. Right-click on the Test\_Peripherals application, then
select Build Configurations → Set Active Release.



Figure 1 – Change to Release Configuration

- 2. In the main SDK menu, select **Project > Build All** to force the new configurations to build.
- 3. In SDK, select the Test\_Peripherals application.





Figure 2 – Select Application to Boot

4. Select Xilinx Tools → Create Boot Image.



Figure 3 – Initial Create Zynq Boot Image Dialog

5. If your dialog is not pre-populated with files as shown above, then your Test\_Peripherals application may have an issue. Click **Cancel**, then right-click on Test\_Peripherals and select **Clean Project**.



- 6. In the dialog, leave the radio button selected for *Create a new BIF file*. BIF stands for Boot Image Format. The BIF is the input file into Bootgen that lists the partitions (bitstream, software) which Bootgen is to include in the image. The BIF also includes attributes for the partitions. Partition attributes allow the user to specify if the partition is to be encrypted and/or authenticated.
- 7. Click on the Secutity Tab. We will not be using Authentication or Encryption, so these checkboxes should be left unchecked. Return back to the Basic Tab

The *Boot Image Partitions* is prepopulated with the FSBL and Application ELF <u>Release</u> images as well as the bitstream. SDK 2017.4 has correctly pulled in the ELFs for our active configurations.

8. The Output Path area actually determines two things, although this is not obvious. Of course, it sets the output file name. The second thing that it determines is whether it creates an image for the SD Card (bin) or the QSPI (mcs). By default, it is set to .bin (SD Card), since the MiniZed by default can't boot from SD, this must be changed. Change the output format to MCS to generate a QSPI image. Change the output file name to Test\_Peripherals.mcs. You should have the same setup and naming conventions as the image below



Figure 4 – Zynq Boot Image Dialog

When complete the dialog should look as above, with the FSBL first, the bitstream second, and the application third

9. Click Create Image.



10. Using Windows Explorer, navigate to the application directory, then into the newly created **bootimage** directory. Notice that two files have been created: .bif and .mcs.



Figure 5 - bootimage Directory

11. Open the Test\_Peripherals.bif file in a text editor. You'll notice that this is a very simple file. The absolute paths to the three files are listed. Close the file.

```
//arch = zynq; split = false; format = MCS
the_ROM_image:
{
    [bootloader]C:\Speedway\ZynqSW\2017_4\SDK_Workspace\zynq_fsbl_0\Release\zynq_fsbl_0.elf
    C:\Speedway\ZynqSW\2017_4\SDK_Workspace\ZynqHW\Z_system_wrapper.bit
    C:\Speedway\ZynqSW\2017_4\SDK_Workspace\Test_Peripherals\Release\Test_Peripherals.elf
}
```

Figure 6 - BIF Contents

## **Questions**

Is the order of the images critical when generating the boot image? If so, list the order.

True or False? The Create Zynq Boot Image tool creates a boot image for the QSPI flash.

True. SDK uses a utility called bootgen to generate a boot container file that contains the FSBL, the Programmable Logic bitstream (optional), and the Standalone user application



## **Experiment 2: Write and boot from QSPI**

First, we will program the QSPI with the MCS file from within SDK. Then we will boot the test application.

#### **Experiment 2 General Instruction:**

Program the QSPI with the MCS file. Disconnect power then change the MODE switch to QSPI. Power on the board and boot from QSPI.

#### **Experiment 2 Step-by-Step Instructions:**

- 1. Set up and turn on your board as before ( USB-UART, and JTAG, turn power on).
- 2. In SDK, select Xilinx Tools → Program Flash.
- 3. Click the **Browse** button, and browse to the SDK\_Workspace\Test\_Peripherals\bootimage folder then select the Test\_Peripherals.mcs image. Select it and click **Open**.
- 4. Now we must specify the FSBL file, click the **Browse** button and browse to the SDK\_Workspace\zynq\_fsbl\_0\Release folder and then select the zynq\_fsbl\_0\_.elf file
- 5. Click **Program**.



Figure 7 – Program QSPI Flash Memory

6. The operation should take approximately 1 minute. You should see something similar to the following in the console window.



```
****** Xilinx Program Flash
****** Program Flash v2017.4 (64-bit)
  **** SW Build 2086221 on Fri Dec 15 20:55:39 MST 2017
    ** Copyright 1986-2017 Xilinx, Inc. All Rights Reserved.
Connecting to hw_server @ TCP:127.0.0.1:3121
WARNING: Failed to connect to hw_server at TCP:127.0.0.1:3121
Attempting to launch hw_server at TCP:127.0.0.1:3121
Connected to hw_server @ TCP:127.0.0.1:3121
Available targets and devices:
Target 0: jsn-openjtag2-1234-oj1A
        Device 0: jsn-openjtag2-1234-oj1A-4ba00477-0
Retrieving Flash info...
Initialization done, programming the memory
BOOT MODE REG = 0 \times 000000000
f probe 0 0 0
Performing Erase Operation...
Erase Operation successful.
INFO: [Xicom 50-44] Elapsed time = 2 sec.
Performing Program Operation...
0%...50%...100%
Program Operation successful.
INFO: [Xicom 50-44] Elapsed time = 7 sec.
Flash Operation Successful
```

Figure 8 - QSPI Programmed Successfully

- 7. Power off the board by unplugging J2 micro-USB connector.
- 8. Set the MiniZed boot mode switch SW1 to QSPI mode ('F' for Flash) as shown below.





Figure 9 – MiniZed Switch Location





Figure 10 - QSPI/Flash Boot Mode

- 9. Close or disconnect the terminal that may have previously been open on your PC.
- 10. Power on the board by reconnecting the USB-JTAG-UART J2 connection. A blue LED should illuminate meaning the bitstream was loaded.
- 11. Launch a terminal program (TeraTerm) with the 115200/8/n/1/n settings.
- 12. Push the RESET button (SW2). You should see the results in the terminal.





Figure 11 – Results from QSPI boot of Periph\_Test

- 13. Close the terminal.
- 14. Unplug the USB-UART-JTAG cable.

This concludes Lab 7.



**Revision History** 

| Date      | Version | Revision                                   |
|-----------|---------|--------------------------------------------|
| 12 Nov 13 | 01      | Initial release                            |
| 23 Nov 13 | 02      | Revisions after pilot                      |
| 01 May 14 | 03      | MicroZed.org Training Course Release       |
| 10 Dec 14 | 04      | Updated to Vivado 2014.3                   |
| 07 Jan 15 | 05      | Updated to Vivado 2014.4                   |
| 12 Mar 15 | 06      | Finalize SDK 2014.4                        |
| Oct 15    | 07      | Updated to SDK 2015.2                      |
| Aug 16    | 08      | Updated to SDK 2016.2                      |
| Jun 17    | 09      | Updated to 2017.1 for MiniZed + Rebranding |
| Feb 18    | 10      | Updated to Vivado/SDK 2017.4               |

### Resources

www.microzed.org

www.minized.org

www.picozed.org

www.zedboard.org

www.xilinx.com/zynq

www.xilinx.com/sdk

www.xilinx.com/vivado

www.xilinx.com/support/documentation/sw manuals/ug949-vivado-design-methodology.pdf

 $\underline{www.xilinx.com/support/documentation/sw\_manuals/ug1046-ultrafast-design-methodology-guide.pdf}$ 

## **Answers**

• Is the order of the images critical when generating the boot image? If so, list the order.

YES! FSBL ELF, then (optional) bitstream, then application ELF

 True or False? The Create Zynq Boot Image tool creates a boot image for the QSPI flash..

True. SDK uses a utility called bootgen to generate a boot container file that contains the FSBL, the Programmable Logic bitstream (optional), and the Standalone user application.

